草庐IT

java - Google App Engine 上的 GSON 抛出安全异常

全部标签

ruby-on-rails - ActiveSupport::SecureRandom 如何安全?

ActiveSupport::SecureRandom是否安全,因为它“不可能”计算出随机数,或者它返回UUID的方式是否安全? 最佳答案 随机数(及其应用)的安全性来自于它对于加密目的的随机性。随机性的质量在很大程度上取决于系统可以提供的熵,例如通过Linux上的/dev/urandom接口(interface)。为了安全起见,给定先前生成的随机数的某个序列,攻击者不能猜测下一个随机数。您可以使用ActiveRecord::SecureRandom作为创建UUID的实现的一部分(版本4)但它们没有直接关系

ruby-on-rails - 如何正确捕获 Controller 操作中的异常?

有如下代码:defindex@posts=User.find_by(login:params[:user_id]).postsend如您所见,如果没有用户登录,此代码会生成异常(无指针异常)。我怎样才能捕获这个异常并正确处理它?我知道如何在Ruby中捕获异常,但我想知道如何以良好的Rails风格来做。同样的问题可能发生在不同的Controller中——也许我应该创建一个Action包装器,捕获异常并呈现500错误? 最佳答案 最简单的方法是使用ApplicationController的rescue_from:classApplic

ruby - 如何安全地让用户运行任意 Ruby 代码?

我意识到这听起来有点疯狂,但我正在做一个项目,我需要一个服务器来运行用户提供的Ruby代码并返回结果。我想防止这样的事情发生:system("rm-rf/")eval("something_evil")#etc...我确信一定有一些相当安全的方法可以做到这一点,因为它已经存在于tryruby.org等地方。非常感谢任何帮助,谢谢! 最佳答案 三个建议:1)看看Rubytaintlevels.这提供了一定程度的保护,防止eval('evil_code')类型的东西,等等。2)除非用户确实需要访问本地文件系统,否则请使用类似fakefs

ruby - 使用安全转换验证使用 Ruby/OpenSSL 创建的 RSA 签名

我正在尝试为我的应用程序实现一个简单的许可key方案,但我遇到了重大障碍。我正在按照OpenSSLforLicenseKeys中的示例进行操作.自从该博文写于2004年并且OpenSSL在OSX上已被弃用后,我尝试使用SecurityTransformsAPI代替OpenSSL来完成许可证key验证。但是,我正在使用OpenSSL生成私钥和公钥;许可证key由Ruby网络应用程序使用私钥生成,该应用程序使用来自购买者电子邮件地址的SHA-256摘要的RubyOpenSSL包装器库。问题是,我所做的任何事情似乎都无法使用安全转换API验证的OpenSSL从Ruby生成签名。我正在处理的R

arrays - 从每个数组中删除是否安全?

是否可以在通过each遍历Array时安全地删除元素?第一个测试看起来很有希望:a=(1..4).to_aa.each{|i|a.delete(i)ifi==2}#=>[1,3,4]但是,我找不到确凿的事实:是否安全(设计)从哪个Ruby版本开始它是安全的在过去的某些时候,它似乎是notpossibletodo:It'snotworkingbecauseRubyexitsthe.eachloopwhenattemptingtodeletesomething.documentation没有说明迭代期间的可删除性。我不是在寻找reject或delete_if。我想对数组的元素做一些事情,有

ruby-on-rails - Mac 上的 Rails ActionMailer 问题

过去几天我一直在努力学习使用Rails,但遇到了一些我无法通过Google解决的问题。所以我只是创建了一个发送电子邮件的基本联系表单。在测试中一切似乎都正常,这告诉我表单正在工作,并且ActionMailer已正确实现,但是,我在配置ActionMailer时遇到了问题。我正在运行OSX10.6.2。我正在运行postfix,并已使用telnetlocalhost25验证它正在运行。当我尝试使用该表单时,出现“连接被拒绝”错误。这是我当前的配置:config.action_mailer.smtp_settings={:address=>'localhost',:port=>25}我想我

ruby - OSX Mountain Lion 上的默认 Ruby 版本?还是 1.8.x 或 1.9.x?

OSXMountainLion上的默认Ruby版本是什么?还是1.8.x或1.9.x? 最佳答案 在MountainLion上,它是Ruby1.8.7-p358(使用OSX10.8和10.8.3测试):$sw_versProductName:MacOSXProductVersion:10.8.3BuildVersion:12D78$/usr/bin/ruby-vruby1.8.7(2012-02-08patchlevel358)[universal-darwin12.0] 关于ruby-

ruby-on-rails - rails 4.0 上的 haml-rails?

我想知道是否有人在使用Rails4.0中的haml-railsgem时遇到过任何问题。有一个RailsCast那说有一些问题,但没有更多提及这一点。托管在GitHub上的gem也没有明确提及对Rails4.0的支持。那么这方面的进展如何? 最佳答案 我在Rails4项目中使用haml-rails(0.4),一切正常 关于ruby-on-rails-rails4.0上的haml-rails?,我们在StackOverflow上找到一个类似的问题: https:/

ruby - 为什么 Ruby 使用自己的安全导航运算符语法?

Ruby2.3.0引入了安全导航语法,它通过引入一个新的运算符来简化链式方法调用的nil处理,该运算符仅在先前语句的值不是nil。这是一个已经存在于C#、Groovy和Swift中的特性。例如inGroovy,语法是foo?.bar这基本上意味着结果值是foo.bar除非foo是null,在这种情况下返回值也是null因此不会抛出异常。还有C#(称为空条件运算符)和Swift(称为可选链接表达式)使用此表示法。所以语法在其他语言中似乎是相当标准的。现在,为什么在Ruby中语法是foo&.bar代替? 最佳答案 此答案基于thedis

ruby - 要求命令在 Snow Leopard 上的 bash irb 中不起作用

我正在研究ZedShaw的“艰难学习Ruby练习25”http://ruby.learncodethehardway.org/ex25.html当我导航到包含ruby​​文件ex25.rb的目录并启动IRB时,我收到以下错误:Larson-2:~larson$cdRubyLarson-2:Rubylarson$lsex25.rbLarson-2:Rubylarson$irbruby-1.9.2-p290:001>require'ex25'LoadError:nosuchfiletoload--ex25from/Users/larson/.rvm/rubies/ruby-1.9.2-p2